home *** CD-ROM | disk | FTP | other *** search
/ Language/OS - Multiplatform Resource Library / LANGUAGE OS.iso / gnu / smaltalk.lha / smalltalk-1.1.1 / SharedQueue.st < prev    next >
Text File  |  1991-09-12  |  2KB  |  83 lines

  1. "======================================================================
  2. |
  3. |   SharedQueue Method Definitions
  4. |
  5.  ======================================================================"
  6.  
  7.  
  8. "======================================================================
  9. |
  10. | Copyright (C) 1990, 1991 Free Software Foundation, Inc.
  11. | Written by Steve Byrne.
  12. |
  13. | This file is part of GNU Smalltalk.
  14. |
  15. | GNU Smalltalk is free software; you can redistribute it and/or modify it
  16. | under the terms of the GNU General Public License as published by the Free
  17. | Software Foundation; either version 1, or (at your option) any later version.
  18. | GNU Smalltalk is distributed in the hope that it will be useful, but WITHOUT
  19. | ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
  20. | FOR A PARTICULAR PURPOSE.  See the GNU General Public License for more
  21. | details.
  22. | You should have received a copy of the GNU General Public License along with
  23. | GNU Smalltalk; see the file COPYING.  If not, write to the Free Software
  24. | Foundation, 675 Mass Ave, Cambridge, MA 02139, USA.  
  25. |
  26.  ======================================================================"
  27.  
  28.  
  29. "
  30. |     Change Log
  31. | ============================================================================
  32. | Author       Date       Change 
  33. | sbyrne     25 Apr 89      created.
  34. |
  35. "
  36.  
  37. Object subclass: #SharedQueue
  38.        instanceVariableNames: 'queueSem valueReady queue'
  39.        classVariableNames: ''
  40.        poolDictionaries: ''
  41.        category: nil!
  42.  
  43. SharedQueue comment: 
  44. 'My instances provide a guaranteed safe mechanism to allow for communication
  45. between processes.  All access to the underlying data structures is
  46. controlled with critical sections so that things proceed smoothly.' !
  47.  
  48.  
  49. !SharedQueue class methodsFor: 'instance creation'!
  50.  
  51. new
  52.     ^super new init
  53. !!
  54.  
  55.  
  56.  
  57. !SharedQueue methodsFor: 'accessing'!
  58.  
  59. next
  60.     | result |
  61.     valueReady wait.
  62.     queueSem critical: [ result _ queue removeFirst ].
  63.     ^result
  64. !
  65.  
  66. nextPut: value
  67.     queueSem critical: [ queue addLast: value ].
  68.     valueReady signal.
  69.     ^value
  70. !!
  71.  
  72.  
  73.  
  74. !SharedQueue methodsFor: 'private'!
  75.  
  76. init
  77.     queue _ OrderedCollection new: 10.
  78.     valueReady _ Semaphore new.
  79.     queueSem _ Semaphore forMutualExclusion
  80. !!
  81.